Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Require newer version for py-setuptools explicitly to ensure py-onnx builds #671

Closed
wants to merge 1 commit into from

Conversation

tmadlener
Copy link
Contributor

Without this I run int a weird build error for py-onnx (see below). It's also not entirely clear to me why it picks up a lower version of py-setuptools, because purely from the dependency graph it should actually get py-setuptools@69

==> py-onnx: Executing phase: 'install'
==> Error: ProcessError: Command exited with status 1:
    '/home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/python-venv/1.0-ttdjab/bin/python3' '-m' 'pip' '-vvv' '--no-input' '--no-cache-dir' '--disable-pip-version-check' 'install' '--no-deps' '--ignore-installed' '--no-build-isolation' '--no-warn-script-location' '--no-index' '--prefix=/home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-onnx/1.15.0-uhi5kz' '.'

2 errors found in build log:
     12      Processing /tmp/madlener/spack-stage/spack-stage-py-onnx-1.15.0-uhi5kzip3kuzggoeg2zjph6wvy4hhyhy/spack-src
     13        Added file:///tmp/madlener/spack-stage/spack-stage-py-onnx-1.15.0-uhi5kzip3kuzggoeg2zjph6wvy4hhyhy/spack-src to build tracker '/tmp/pip-build-tracker-rvymwchc'
     14        Created temporary directory: /tmp/pip-modern-metadata-2h8qti79
     15        Preparing metadata (pyproject.toml): started
     16        Running command Preparing metadata (pyproject.toml)
     17        fatal: not a git repository (or any of the parent directories): .git
  >> 18      /home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-setuptools/62.6.0-r6oim4/lib/python3.11/site-packages/setuptools/config/pyprojecttoml.py:104: _BetaConfigu
             ration: Support for `[tool.setuptools]` in `pyproject.toml` is still *beta*.
     19          warnings.warn(msg, _BetaConfiguration)
     20        running dist_info
     21        creating /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info
     22        writing /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info/PKG-INFO
     23        writing dependency_links to /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info/dependency_links.txt
     24        writing entry points to /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info/entry_points.txt

     ...

     2865    Building wheels for collected packages: onnx
     2866      Created temporary directory: /tmp/pip-wheel-7sa9hgv_
     2867      Destination directory: /tmp/pip-wheel-7sa9hgv_
     2868      Building wheel for onnx (pyproject.toml): started
     2869      Running command Building wheel for onnx (pyproject.toml)
     2870      fatal: not a git repository (or any of the parent directories): .git
  >> 2871    /home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-setuptools/62.6.0-r6oim4/lib/python3.11/site-packages/setuptools/config/pyprojecttoml.py:104: _BetaConfigu
             ration: Support for `[tool.setuptools]` in `pyproject.toml` is still *beta*.
     2872        warnings.warn(msg, _BetaConfiguration)
     2873      running bdist_wheel
     2874      running build
     2875      running build_py
     2876      Traceback (most recent call last):
     2877        File "/home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-pip/23.1.2-2rarbw/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_proce
             ss.py", line 353, in <module>

See build log for details:
  /tmp/madlener/spack-stage/spack-stage-py-onnx-1.15.0-uhi5kzip3kuzggoeg2zjph6wvy4hhyhy/spack-build-out.txt

BEGINRELEASENOTES

  • Require a new enough version of py-setuptools to build py-onnx

ENDRELEASENOTES

…builds

Without this I run int a weird build error for py-onnx (see below). It's also not entirely clear to me why it picks up a lower version of py-setuptools, because purely from the dependency graph it should actually get `py-setuptools@69`

```console
==> py-onnx: Executing phase: 'install'
==> Error: ProcessError: Command exited with status 1:
    '/home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/python-venv/1.0-ttdjab/bin/python3' '-m' 'pip' '-vvv' '--no-input' '--no-cache-dir' '--disable-pip-version-check' 'install' '--no-deps' '--ignore-installed' '--no-build-isolation' '--no-warn-script-location' '--no-index' '--prefix=/home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-onnx/1.15.0-uhi5kz' '.'

2 errors found in build log:
     12      Processing /tmp/madlener/spack-stage/spack-stage-py-onnx-1.15.0-uhi5kzip3kuzggoeg2zjph6wvy4hhyhy/spack-src
     13        Added file:///tmp/madlener/spack-stage/spack-stage-py-onnx-1.15.0-uhi5kzip3kuzggoeg2zjph6wvy4hhyhy/spack-src to build tracker '/tmp/pip-build-tracker-rvymwchc'
     14        Created temporary directory: /tmp/pip-modern-metadata-2h8qti79
     15        Preparing metadata (pyproject.toml): started
     16        Running command Preparing metadata (pyproject.toml)
     17        fatal: not a git repository (or any of the parent directories): .git
  >> 18      /home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-setuptools/62.6.0-r6oim4/lib/python3.11/site-packages/setuptools/config/pyprojecttoml.py:104: _BetaConfigu
             ration: Support for `[tool.setuptools]` in `pyproject.toml` is still *beta*.
     19          warnings.warn(msg, _BetaConfiguration)
     20        running dist_info
     21        creating /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info
     22        writing /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info/PKG-INFO
     23        writing dependency_links to /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info/dependency_links.txt
     24        writing entry points to /tmp/pip-modern-metadata-2h8qti79/onnx.egg-info/entry_points.txt

     ...

     2865    Building wheels for collected packages: onnx
     2866      Created temporary directory: /tmp/pip-wheel-7sa9hgv_
     2867      Destination directory: /tmp/pip-wheel-7sa9hgv_
     2868      Building wheel for onnx (pyproject.toml): started
     2869      Running command Building wheel for onnx (pyproject.toml)
     2870      fatal: not a git repository (or any of the parent directories): .git
  >> 2871    /home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-setuptools/62.6.0-r6oim4/lib/python3.11/site-packages/setuptools/config/pyprojecttoml.py:104: _BetaConfigu
             ration: Support for `[tool.setuptools]` in `pyproject.toml` is still *beta*.
     2872        warnings.warn(msg, _BetaConfiguration)
     2873      running bdist_wheel
     2874      running build
     2875      running build_py
     2876      Traceback (most recent call last):
     2877        File "/home/madlener/work/.spack/spackages/skylake-ubuntu24.04-gcc13.2.0/py-pip/23.1.2-2rarbw/lib/python3.11/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_proce
             ss.py", line 353, in <module>

See build log for details:
  /tmp/madlener/spack-stage/spack-stage-py-onnx-1.15.0-uhi5kzip3kuzggoeg2zjph6wvy4hhyhy/spack-build-out.txt
```
@jmcarcell
Copy link
Member

I just built a new py-onnx and I didn't need this. I think this can happen because often multiple versions of py-setuptools are built. Then I don't know how this restriction would interact with that, for example currently on a clean build on Alma9 I see there are three versions:

drwxr-sr-x.   4 root root 4.0K Jan 20 12:19 57.4.0-cco3cr
drwxr-sr-x.   4 root root 4.0K Jan 20 12:19 69.2.0-w5iy64
drwxr-sr-x.   4 root root 4.0K Jan 20 23:48 75.8.0-wmhxj3

@tmadlener
Copy link
Contributor Author

Yeah, this is one of the weird ones, where unified concretization doesn't necessarily land on one version and the one you get at build time seems to be somewhat random. Or at least I haven't found out how the actual version is chosen for a given package.

If this happens again it might be worth investigating a bit more and potentially open an issue with spack itself.

@tmadlener tmadlener closed this Jan 22, 2025
@jmcarcell
Copy link
Member

I believe it is stated somewhere that even for concretizer:unify some build tools like py-setuptools are allowed to have multiple versions because otherwise it would be impossible to concretize as there are packages that require disjoint ranges. I have also seen this issue in the past and it seems to appear and disappear 🤷

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants